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5 NOVEL METHOD AND APPARATUS FOR 

6 CONTROLLING VIDEO PROGRAMMING 

7 
8 

9 

10 Cross-Reference to Related Applications 

1 1 This patent claims priority based on U.S. Patent Application 09/344,442, filed 

12 June 25, 1999; 09/378,184. filed August 20, 1999; 09/378,270, filed August 20, 1999; 

13 and 60/1 1 8,505, filed February 3, 2000, each incorporated herein by reference in its 

14 entirety. 

15 Background of the Invention 

16 This invention pertains to remote control devices for controlling a television, 

17 There are numerous types of remote control devices used for controlling a 

1 8 television. One type of remote control device comprises a numeric keypad for punching 

19 in the number of a desired television channel, as v^cll as buttons for selecting other 

20 options. Other types of remote control devices move a cursor on a screen to select a 

2 1 desired option. These techniques do not usually permit a viewer to preview a channel 

22 option before that option is selected. 

23 Another type of option selection scheme is to provide a set of small pictures on a 

24 television screen, and permh a user to "click" on one of the pictures to select an option 

25 corresponding to that picture. Such small pictures are sometimes called "thumbnails." 

26 Unfortunately, one can only put so many thumbnail pictures on a screen due to limited 

27 resolution of the television screen. 
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1 It is an object of our invention to provide an improved method and apparatus for 

2 selecting options for controlling an image display device, e.g. a television, computer 

3 screen, video editing device, or other type of device comprising an image display 

4 

^ Sunimajiy 

6 A method in accordance with one aspect of our invention comprises the step of 

7 displaying multiple video streams on a display device such as a computer monitor or a 
\{ television. In one embodiment, the screen of the display device contains a primary 

9 porlion and a secondary portion. A first oiie of the multiple video streams (hereafter (he 

10 '*main video stream") is displayed on the primary portion of the screen. The second 

I J portion of the stream displays an image containing a plurality of geonietric surfaces. In 

12 one embodiment, the plurality of geometric surfaces are arranged as a polyhedron. At 

1.^ least one of the multiple video streams is mapped onto at least one of the faces of the 

M polyhedron. Typically, several of the multiple video streams are mapped onto associated 

15 ones of the faces of the polyhedron. Alternatively, other faces of the polyhedron display 

16 images such as icons corresponding to an option that an operator can exercise, e.g. 

17 turning the volume of a television up or down, changing a channel, or performing various 

18 video editing functions. 

In accordance with another aspect of our invention, a hand-held remote control 

20 device permits a user to manipulate and/or select the video images mapped onto the 

2 1 geometric surfaces. Jn one embodiment, the position in which the remote control device 

22 is held is associated with the position of the geometric surfaces in the world coordinate 

23 system. (As explained below, the term "world coordinate system" pertains to the 
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1 orientation of an image displayed on a display screen.) Thus, by rotating llie remote 

2 control device, one can rotate those geometric surfaces. 

In one embodiment, the main video stream is mapped onto a flat geometric 

4 surface. By rotating the remote control device, one can also rotate the Hat geometric 

s surface upon which the main video stream is mapped. 

6 In accordance with another embodiment of the invention, the hand-held remote 

7 control device has a scrolling wheel. By rotating the wheel, one can rotate one or more 

8 of the geometric surfaces upon which images are mapped. In one embodiment in which 
the plurality ofgeometric surfaces form a polyhedron, by rotating the wheel, one caji 

10 rotate the polyhedron. By rotating the wheel, one can also rotate the surface upon which 

1 1 the main video stream is mapped. 

12 In accordance with another embodiment of the invention, the had-held remole 
l.T control device comprises a track ball. By rotating the track ball, one can rotate one oi 
14 more of the geometric surfaces upon Avhich images are mapped. In one embodiinenl on 
\5 which the plurality ofgeometric surfaces form a polyhedron, by moving the track ball, 

16 one can rotate the polyhedron. By moving the track ball, one can also rotate the surface 

17 upon which the main video stream is mapped 

18 As mentioned above, in one embodiment, video streams are mapped onto the 

19 various faces of a polyhedron, and rotating the hand-held remote control device results in 

20 rotation of the polyhedron. (In one embodiment, the polyhedron can rotate about only 

21 one fixis. In another embodiment, it can rotate about more than one axis.) A control 

22 element on the remote control device, e.g. a button or switch, can be used to select which 
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1 linage on a polyhedron face is to be shown on the primary portion of the display device 

2 as the main video stream. 

3 In one embodiment, llie hand-held remote control device is held by a user who 

4 can rotate (he remote control device, e.g. about any desired axis. Means are provided 

s witliin the remote control device for sensing motion ajid/or position of the remole control 

6 device, and comniunicating to a receiver within the television that motion and/or position. 

7 A receiving circuit within the television causes the image of the polyhedron to rotate or 

8 move in a manner that inirrors the motion of the remote controller. When a &ce of the 

9 polyhedron depicting an image representing a desired option is facing the user, he can 

10 actuate a button or other control device on the remote contioller to select that option. 

1 1 I n another embodiment, instead of displaying a polyhedi on, the inenu options 
\2 displayed on (he video screen can be displayed in another form. However, different 

1.1 menu options can be displayed and/or selected in response to the motion and/or position 

hi of the remote control device. 
J 5 

1^' ! jesc the Drawiiigs 



17 Pigs. lA (o IH illustrate the operation ofa 3D graphics pipeline. 

18 Figs. 2A and 2l.i illustrate manipulation ofa 2D image. 

I^J F'ig. 3 is a simplified block diagram ofa personal computer (PC) coupled to a 

20 graphics controller with a 3D graphics pipeline. 

21 Fig. 4 illustrates a television displaying an image of a polyhedron constructed in 

22 accordance with our invention. 
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I Fig. 5 illustrates a remote control device for controlling the television comprising 

1 position or motion sensors. 



1 



Fig. 6 illustrates a remote control device for controlling the television comprising 

■\ a track ball. 

5 iMg. 7 illustrates a remote control device for controlling the television comprising 

u a rotating wheel. 

7 iMg. 8 illustrates a television displaying a band of images. 

DetailedJDescri^^^ 

10 As mentioned above, a method in accordance with our invention involves 

1 1 displaying an image of a polyhedron on a television or other display device. Eiach face of 

12 I he polyhedron depicts an image representing an option that can be taken by someone 
1 1 operating the television. 

14 The polyhedj on and the images on the iaces of the polyhedron are generated 

13 using a 3D graphics pipeline in a novel manner. In order to explain the manner in which 
16 the polyhedron and images are generated, we will first explain how a 3D graphics 

i? pipeline is normally used. We will then describe its use during a method in accordance 

IK with the invention. We will then describe remote control devices that can be used to 

19 manipulale the orientation of the polyhedron. 
20 

2 1 3D Graphics Pi pelines 

22 The 3D graphics pipeline referred to in this patent can be implemented by a 

2.3 combination of hardware elements, known as accelerators, and software, some of which 

24 is sometimes referred to as drivers. The partitioning between hardware and software may 
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1 vary, depending upon the CPU used and the graphics card in the system, but the overall 

2 syst em performs the method steps described below. Portions of the pipeline tasks can be 
"i performed by sofl:ware, which is less expensive than hardware, but in general slower than 
1 hardware sohjtions at the present time. The hardware and software lhal perform the steps 

5 described below are referred to simply as a pipeline, without regard to the specific 

6 partitioning. 

7 The following is a simplified, general description of 3D graphics pipelines. It is 

8 not intended to describe any specific product (e.g. products mentioned later in this 

y patent). Rather, the following description is merely a general explanation of 3 D graphics 

10 pipelines to assist the reader's understanding. 

1 1 (Currently, graphics objects created using a 3D graphics pipeline can be described 

12 as a set of geometric surfaces. One way of constaicting a geometric surface in a graphics 

13 pipeline is to create a "mesh" of "primitives." A "primitive" is a small geometric surface 

14 thai can be defined by a set of vertices. F'or example, the primitive can be a polygon (e.g. 

15 a triangle or quadrilateral) defined within the pipeline in terms of the locations (in x, y 

16 and z coordinate space) of its corners or vertices. A set of several primitives is used to 

17 define a larger 3D surface. 

18 Instead of using primitives, such as polygons, some graphics pipelines can 

10 process geometric surface areas defined in other ways, e.g. by mathematical equations 

20 This technique for defining geometric surface areas is called "implicit." As explained 

21 below, both techniques tor defining such surface areas can be used. 
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l^-or purposes of clarity ofexplanaiion, we will first describe a grapJiics pipeline 
lhat processes geometric surface areas using triangular primitives. Other types of 
graphics pipelines will be discussed later on. 

In this first exa/nple, a 3D graphics pipeline constructs a 3D image of an object 
from a 2D pixel array (typically called a ^'texture map''). Fig. 1 A illustrates a 2D image 2 
of a set of "textures." (As will be explained below, this texture map is used to create the 
image of an object—in this case, a house. Image 2 includes a portion 2a, which has the 
appearance of bricks, portion 2b, which has the appearance of roof shingles, portion 2c, 
which has the appearance of a door, and portion 2d which has (he appearance of a 
window.) 2D image 2 is stored in a digital memory in the form of an array of pixels. 
Each localion in the memory stores a pixel, which is one or moi e words of data indicating 
the color, color saturation and brighhiess corresponding to that pixel. The location of the 
pixels within ihe array is typically referred to as u, v coordinates (not to be confused with 
the Y, U and V signal names used to describe certain video signals), (l^he u, v 
coordinales are similar to x, y coordinates of the Cartesian coordinate system. In Fig. 1 A, 
the i)ixcl array is an n by m array, where n and m are integers.) 

As mentioned above, Fig. I A represents a pixel an ay. Physically, the array 
comprises data loaded into a memoi-y. 

The next step in <he process is to provide or prepare a geometric surface. In this 
example, I he geometric surface is in the form of a mesh 4 of primitives 5 in three 
dimensional space (Fig. I B). In the case of Fig IB, the primitives are triangles, but other 
types of polygons can be used. The mesh of primitives represents a three-dimensional 
sJiape of an object O in 3D space (in the case of Fig. IB, the shape of a house). The 
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1 position of each vertex of each triangle within mesh 4 is stored in a memory in the form 

2 ofx, y and z Cartesian coordinates, relative to the object. These coordinates are 

3 sometimes referred to as model coordinates ("MC"). The process of preparing such a 

4 mesh is well-known, and described in standard graphics libraries, such as Real 3D, 

i published by Real 3D, aLockhced Martin Corporation, in 1996, and Direct 3D, published 

6 by New Riders Publishing in 1997. 

7 The mesh of FMg. 1 B is not displayed as such. Rather, the mesh of Fig. 1 B is a 

K rcpreseiilation of what is stored in a digital memory. Specifically, the memory siores the 

9 locations, in lenns of x, y and z coordinates, of each vertex within mesh 4. 

10 The next step is to map or "bind" the two-dimensional texture map of Fig. I A 

1 1 onto mesh 4 o(*Fig. IB, This is accomplished by mapping each triangle vertex to a 

12 location in tlie texture map. In effect, a list of data points is prepared that associates each 
1.^ vertex of mesh 4 to the u, v coordinates of a particular point (pixel) in the texture map of 
N Fig. 1 A. (The locations in the texture map to which the vertices are bound are sometimes 

15 referred lo as "control points.") 

16 This poition of the process is roughly analogous to an upholsterer choosing a 

17 piece of fabric, and binding it with a few nails to the corner of a couch being upholstered 

18 ((he nails are like control points). The upholsterer subsequently asks his apprentice to 

19 tlnish attaching the fabric to the couch. In this case, the 3D graphics pipeline finishes the 

20 task instead of an apprentice. 

21 Figs. lAand IB describe the process by which one texture map (Fig. lA)is 

22 mapped onto one mesh 4 representing one object 0. A graphics pipeline can, and oflen 

23 does, map one or several texture maps onto the same or several different objects 
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'Mie next step in the process is to set up a "world coordinate model" of the various 
objects to be displayed. This requires establishing a position and directional orientation 
for each object lo be displayed. J'or example, supposing that there are to be two objects 
to be viewed: a tetrahedron T and a cube C (iMg. IC). During this step of the process the 
pipeline is instructed that cube C is to be facing in a certain direction, and is to be located 
partially in Iront of tetrahedron T relative to a ceitain frame of reference. Again, the 
structure of Fig. IC is not displayed per se. Rather, the graphics pipeline sets up 
processing of the model coordinates in accordance with the parameters of tlie position 
and orientation of the object, 

I he next step is to select a frame of relerence. For example, it might be decided 
that tlie "viewer" will want to observe the objects from a position corresponding to a 
corner of the world coordinate model (e.g. position P in Fig. ID). Thus, a virtual 
viewpoint, viewing direction and aperture will be selected. The parameters associated 
with this "viewer" define the screen coordinate (SC) system. Further, it might be decided 
tJie viewer will observe these objects with a light source located at a position L. ^flic 
graphics pipeline will set up another processing pipe to ()rocess the world coordinate data 
ijito the sci een coordinate data which will cause a computer screen lo display the image 
as it would be perceived by the observer at position P (e.g. the image of Fig. I D). I n 
olher words, the computer screen will provide an image of tetrahedron T and cube C as 
tliey would be observed by a viewer if he were standing at position P, and a light source 
were present at location L, This image will be provided initially as a pixel array in a 
frame bunfej- and then displayed by the computer screeji. The image in the frame buffer 
is refreshed, i.e. regenerated according to the specifications programmed into the 
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1 pipeline, typically at about 50 to 120 times per second. There are many difiercnt 

2 nielhods lor optimizing the pipeline, and nninirnizing the time spent processing the 
^ invisible parts of the objects, such as the backside of cube C facing away Iiom the 

4 viewer. Such details are well-lcnown to those skilled in the art, and will not be discussed 

5 in detail here. 

6 During the above-described process constructing the pixel array and providing il 

7 in the frame buifer, the pipeline a) letches the portion of texture map 2 "tacked" to the 
H vertices of mesh 4 (and therefore stretched over each triangle); b) determines liow and 

y where thai portion of the texture map should appear, given the orientation of the triangles 

10 relative to the viewer and the location of the light source; and c) constructs the 

1 1 appropriate bit map pixel array for storage in the frame buffer. The contents of this frame 
i:i birfTer are then displayed as an image on a computer screen. 

11 Thereafler, the 3D graphics accelerator permits one to manipulate the displayed 

14 objects in any desired manner. For example, if one wants to rotate the image of 

15 tetrahedron T by 45^' (Fig. 1 E\ the 3D graphics accelerator facilitates this manipulation. 

16 T'liis is accomplished by providing a new set of parameters in the world coordinate model 

17 for the graphics pipeline indicating the new position and orientation for tetrahedron l . 
IK After this occurs, the next time the graphics pipeline regenerates the image stored in the 
ly frame buffer, the regenerated image will reflect this rotation of tetrahedion T. 

20 Similarly, suppose that it is desired to display what would appear to the viewer if 

21 he took ten steps forward from his location at position P. The next time the graphics 

22 pipeline i cgenerates the image, it will generate and store another pixel array in the frame 
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I bulTer corresponding to what would appear to such a viewer, and this pixel array is 
i provided as another image on the computer screen. 

It is thus seen that the graphics pipeline is extremely useful in applications such as 

A video games, where it is desired to simulate what would appear lo a game player if he 

5 were wandcri ng past a set of objects. 

0 As mentioned above, some graphics pipelines create models of geometric surfaces 

7 using an implicit technique. These surfaces are often described as a tiinction of the 

H position coordinates, i.e. f (x.y./O, or can also contain some vertices. Control points and 

y additioiial formulas associated with such surfaces are used to bind a digital pixel array 
10 (e.g. an array as shown in Fig. 1 A) to the implicitly detined surface, and the process 

I I proceeds as described above. The major difference is that instead of defining surface 

12 areas in terms of primitives with vertices, the surface areas are defined in terms of 

13 niathematical equations. 
14 

1 5 Manipjll a tknjpi 

As mentioned above, one embodiment of the invention is a remote controller 

17 which cooperates with video graphics circuitry that provides an image of a polyhedron, 

IK each face of the polyhedron displaying an image corresponding to a menu option. I will 

19 now explain how that image is provided. In particular, I will describe a method for 

20 manipulating a two-dimensional image. 

21 A method for manipulating a two-dimensional image begins with the step of 

22 obtaining a two-dimensional digital image (e.g. image 10 in Fig. 2A). This step can be 
2.^ perlbrmed, e.g., by scanning an image such as a photograph or other picture using a 
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I conveni ional digital scanner. The digital image can also be obtained from a convcnLional 

1. digital camera. The image can also consist ofdigital video image, e.g. out of a live or 

'S stored video stream, which is basically a fast succession of 2D images. However, any 

4 other source of a 2D digital image can be used. The digital image is typically stored in a 

.s memory as an array of digital values. In one embodiment, the digital values are in a 

6 compressed form, e.g. using a compression technique such as MPEGI or MPEG2 or 

7 other formats. In the case of compressed digital values, they must first be decompressed 
X prior to processing. Also, scanned images or digitized images from any source such as 

<; cable TV, an antenna, cameras, etc. can be used. 

JO As mentioned above, for the case of video images, dozens of frames per second 

1 1 comprising millions of pixels per second musi be processed. We discovered that slandard 

12 graphics pipelines can be used to process frames of data sufficiently fast to process video 
l.'i images. 

14 Any type of memory can be used to store the digital 2D image, e.g. 

15 semiconductor memories (SRAMs, DR AMs or other semiconductor memories), a 

16 magnetic memory (e.g. a hard disk, a floppy disk, magnetic tape, or magneto-optic disk), 

17 or other type of memory device (e.g. an optical disk). The pixels corresponding to the 

18 Stored image can be stored in terms of RGB values (e.g. the strength of the red, green and 
blue components of the pixel color), YUV values or other values. (For YIJV values, Y 

20 corresponds to the amplitude or brightness of the pixel value, U corresponds to the color 

21 and V corresponds to the saturation.) The pixel values can be encoded in othej* ways as 

22 well. Depending on the situation, a conversion may be required before further 
2.1 processing. 
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1 Next, a 3D graphics pipeline is set up. This is accomplished by providing 

2 itistructions to ihe 3D graphics pipdine as to what is (o be done with the data that is to be 
^ provided. Setting up graphics pipelines per se is well known in the art, e.g. as described 

4 in the Microsoft Direct 3D SDK (software developer kit) or Direct 3D. 

5 Thereafter, a computer model ofa planar geometric surface is generated. This 
(i computer model can comprise a set of primitives, e.g. polygons such as triangles. Jn 

7 another embodiment, the computer model can comprise an implicit description ofa flat 
« geometric surface. This implicit description is typically a mathematical function (e.g. a 
y fund ion of x, y and z) as described above. 

10 For the case in which the planar geometric surface comprises a mesh of 

1 1 primitives, the number and shape of primitives and the type of primitives can vary. Fig. 
\2 2B illustrates a mesh 1 2 that can be used to practice a method in accordance with our 

i:. invention. Mesh 12 is similar to mesh 4 described above. However, unlike mesh 4, all of 

the vertices of mesh 1 2 are coplanar (or substantially coplanar). In one embodiment, 

1.5 mesJi 12 comprises about 5000 triangles, which would be acceptable for processing a 

16 video image. Of course, other numbers of primitives could be used. 

17 After constructing the planar geometric surface (e.g. mesh 12), image 10 is 

18 iriapped, or bound, onto the flat geometric surface. This is accomplished in the following 
ly way. For the case in which the flat geometric surface is a mesh such as mesh 12, each 

20 vertex of Ihe Hat geometric surface (e.g. the triangle vertices) is associated with an image 

21 pixel location (i.e. control point). Thus, each control point is associated with a texture 

22 coordinates (u, v) corresponding to a pixel. A table of data listing each vertex and its 

2.1 associated u, v texture space coordinates is set up. This is called "binding." (See Kamen, 
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1 ll'EK Computer Society, IEEE Computer Graphics and Applications. Jan -Feb. 1997, 

2 Vol 1 7, No. I .) I'or the case in which an implicit technique is used to define the flat 

.1 geomeiric surface, control points within the implicitly defmed surface are bound to pixel 

4 array coordinate space (u, v coordinates) in a manner analogous to the triangles discussed 

5 above. 

6 After image 1 0 is mapped into mesh 12. the object can be manipulated by 

7 manipulating the world coordinates. The world coordinates describe where in the x, y, ?. 
K space the textured plane is to appeal-, and what its orientation will be (i.e. what angle it 

should be held at with respect to the viewer). In addition, (he screen coordinates for the 
objecl can be changed. As a resull. when the 2D textuied image is finally prepaied, it can 
be prepared in such a manjier that reflects the desired manipulation. For example, it can 
be rotated about any axis, magnified, shrunk, etc. 

AHer establishing the world coordinate model and screen coordinate model, the 
pipeline prepares an array of pixels in the output irame buffer (OFB). including pixels 
showing the manipulated textuied mesh 12. The array of pi.vels in the OFB is displayed 
on a CRT or other type of screen. 

One can manipulate the video image by, for example, changing the world 
cooidinaic pai-ameters. e.g. telling the pipeline to tilt the video image about any axis 
(including an axis perpendicular lo the screen or in the plane of the screen). Thus, when 
the pipeline regenerates the pixel array in the OFB, ihe regenerated video image will 
appear lilted about the selected axis. Since the pipeline will regenerate the image at a 
preprogrammed rate according to the system used, live video will appear as live video. 
That is because every time a new pixel array is generated, the texture map, which 
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contains tlic incoming video frame bufFer. is reread anil put through the pipeline. Since 
the toxlure mapping process also contains features for pixel interpolation, nii automatic 
resolution adaptation occurs. 

One can bend or warp the image by moving ihe vertices about which the image is 
mapped. Thus, one can aher the flat geometric plane of Fig. 2B to thereby wiu-p the 
image. When the pipeline regenerates the pixel array in the frame bufTer, the image will 
appear warped. 

One can move the vertices so that mesh 10 becomes a cylinder. When the 
pipeline regenerates the pixel array in the frame buffer, (he image will appear wrapped 
around a cylinder. (Of course, the mesh 10 can be altered into other shapes, and the 
image would be wiapped around the other shape.) These modifications could be done at 
a speed that would create the impression in the viewer that the image was being wrapped 
oi warped gradually. 

One could magnify or slii ink images by moving vertices away from or closer lo 
each other, or moving the image closer or further from the viewer in the world a)ordinate 
system, or by re-parameterizing the model coordinate to world coordinate conversion. 

.timlwiuig. and SMwareJi^ 

One embodiment of our invention can be practiced using a PC having the 
following: 

1 . A CPU such as a Celeron or Pentium, e g. as manufactured by Intel, or a K6 
processor, e.g. as manufactuied by Advanced Micro Devices. 

2. 32 MB of memory or greater. 
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13. A 3D HW adapter. This is a (ype of graphics card currently available on the 

1 market. The 3D HW adapter should have 4 MB of memory (preferably 8 MS) 

^ aiKl an advanced graphics port (AGP) interface. (An AGP interface is a type of 

A bus standard that is well-known in the art,) Alternatively, a peripheral connection 

5 interface ("PCF) can be used in lieu of a AGP, The PCf is a type of bus standai d 

<^ that is well known in the art. Examples of appropriate 3D HW adapters include 

7 the TNl -2 available from Kiva, the ATI kage 128, the Matrox G4()0, the Trideni 

8 Blade 3D and the S3 Savage. 

V 4. The operating system can be Windows 95, Windows 98, Win2000, or any other 

10 operating system that supports direct 3D. The Windows operating system 

i I includes a standardized platform called Direct X for Windows. 

12 \\\ one embodiment, a user sets up the flat geometric surface (for example, a 



l.T triangle mesh) in the Direct 3D windows environment. The set of instmctions is then 

14 provided lo the graphics pipeline, which finishes the rendering process. However, in 

l.s another embodiment, the PC comprises a bypass mechanism that permits one to access 

16 the hardware accelerator directly using a software interface provided by the graphics card 

17 manufacturer. 

l« Fig. 3 is a block diagraiii of a computer system 50 for generating images that can 

19 [>e used in accordance with the invention. Referring to Fig. 3, system 50 comprises a 

20 CPU 52, e.g. a Pentium II class CPU, comprising a cache memory 52a, a core 52b and an 

21 internal bus 52c for facilitating communication between core 52b and cache 52a. Core 

22 52b communicates via a CPU bus 54 to a system controller 56. System controller 56 
03 connnunicates with the system memory 58 via a memory bus 60. System memory 58 
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1 includes a first portion 58a which stores system memoi-y programs and a second portion 

2 58b thai: stores the texture maps such as described above. 

^ Also included in system 50 is a PCI bus 62 for facilitating comnmnicatioji 

4 between system controller 56 and 1/0 devices ()4, 66 and optionally a disk drive 68. 1/0 

s device M can be any type of I/O device. In one embodiment, 1/0 device 64 is a network 

6 interface adapter "NIA'* for receiving signals fi om any type of network, including but nol 

7 limited to salellite broadcast, cable broadcast, telephony, fiber and topologies such as 

K Wide Area Networks (including the Internet), t.ocal Area Networks, Local Multiple Drop 

y Networks etc. In some embodiments, 170 device 64 can be a modem, and in others 1/0 

10 device 64 is a tuner for receiving television signals etc. 

11 In one embodiment, 170 device 66 is a video capture card with a driver. Data 

12 From the video capture card is either loaded by DM A (direct memory access) or CPL) 52 

13 into a Irame bufler, typically within main memory 58. However, the frame buffer may be 

14 in other memories within system 50. In some embodiments, multiple video streams or 

15 image sources are available, such as local storage, capture card 66, NIA 64 or other, no! 
10 explicitly shown sources. 

17 System 50 also includes an AGP graphics controller 70 comprising a 3D 

IK accelerator. In one embodiment, AGP graphics controller 70 communicates with system 

19 controller 56 via an AGP bus 72. In an alternative embodiment, AGP graphics controller 

20 70 can communicate with system controller 56 via PCI bus 62 (e.g. as shown in phantom 

21 in Fig. 3). 

22 Graphics controller 70 uses its own local memory 74 to generate and store pixel 
21 arrays to be displayed on a video display unit 76, 
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1 It is emphasized lhal system 50 is only one example ofa system that peilbrms a 

2 method in accordance with our invention. Other hardware can be used as well. 

.1 The above-mentioned method can be used to manipulate image streams such as 

4 television images. This method is particularly appropriate since video images comprise a 

5 succession of frames at a rate of about 60 frames/second in North America. For instance 

6 in the case of NTSC, about 9. 1 Mbytes per second throughput are required. (NTSC is an 

7 abbreviation of "North American Television Standard for Color. It is the standajd used 

8 for television signals in North America.) 

y The system of Fig. 3 can move and tilt portions of different video images or other 

10 images onto different portions of a screen such as a television screen. In one 

1 1 embodiment, the images are transformed to appear on the faces ofa polyhedron (e.g. a 

12 cube). As explained below, the polyhedron is used as a new type of television menu 

1.1 option display. In particular, a novel remote control device (described below) permits a 

J4 user to turn the polyhedron to see the different; images on the various faces of the 

15 polyhedron. Aiter the polyhedron is turned in an appropriate orientation, one can *'click" 

16 on a desired polyhedron face, or a portion ofa desired polyhedron face, to select a desired 

17 option. 

IH The manipulated image provided in accordance with our invention can be 

J.9 provided to any appropriate output device, e.g. a television screen, a video projector, a 

20 Hf)TV monitor, or a PC screen. The image manipulated in accordance with our 

21 invention could come from any of a number of sources, e.g. an analog or digital video 

22 input, a cable TV input, a satellite input, the internet, a digital scanner, a digital camera. 
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I or numerous other sources. (In the case of an analog input, one would first digitize the 

i image.) 

3 

4 ReiTiQLeConMLI>^^ 



Fig. 4 illustrates a television 200 in which the television screen 201 is divided into 
a primary portior) 202 and a secondary portion 203. Primary portion 202 displays a 

H primary video image. Secondary portion 203 depicts a polyhedron 204 in accordance 

y with the invention. Television 200 includes a controller 205 for generating an image of 

10 polyhedron 204. This controller can include the hardware elements depicted in Tig. 3. 

i I 1*hc faces of polyhedron 204 can depict video images, e.g. images of what appears on the 

1 2 various television channels. A given face of polyhedron 204 can also include both video 

13 images and additional information (e.g. in the form of alphanumeric characters or icons), 
N e.g. ihe program name, channel number, etc. Jn addition, the faces of the polyhedron can 

15 depict icons concerning various options, e.g. options related to television volume, on/olT 

16 switches, control of a VCR, options related to editing video images, etc. (Ijiiages 

17 corresponding to such icons are stored in a memory within television controller 205.) 
IH Any appropriate screen and display technology can be used for television 200. 
19 Television 200 is controlled by remote control device 206, which communicates with 

21) television 200 by emitting a signal, e.g. an infrared, radio or other type of signal that can 

2.1 be transmitted and received. (Remote control devices that communicate with a television 

22 using infrared signals are well known in the art. See U.S. Patent 4,918,439, for example.) 

23 In lieu of, or in addition to emitting an IR or radio signal, remote control device 206 can 

24 be connected to and communicate with televitiion 200 by a wire. 
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, In one embodiment, remote control device 206 has the capability of sensing 

2 motion, e.g. as symbolized by arrow 207, indicating rotation of device 206. Such rotation 

3 is sensed, e.g. by techniques described below. Signals indicating such rotation are 

4 communicated to a receiver within television 200, which in turn sends commands to 

5 controller 205. A 3D pipeline within controller 205 orients polyhedron 204 in a manner 

6 that mirrors motion of remote control device 206, either identically or paitially. Foi' 

7 example, the signal depicting motion of remote control device 206 .can be filtered to 

8 eliminate jerking movements. 

9 Fig. 5 illustrates several features of remote control device 206. Element 211 is a 
JO transmitter for comniunicating with television 200. Element 21 1 is typically ati IR 

1 1 transmitter, but it could also be an ultrasonic, radio, mfignetic induction, or other type of 

J2 non directional communication device. Since IR is somewhat directional, more than one 

n emitter may be used in order to guarantee proper communication while handling remote 

14 control device 206. 

15 Also shown in Fig. 5 are a set of buttons and displays, e.g. light emitting diodes or 

16 liquid crystal displays, possibly tTackbaUs, etc., symbolized as three fields 212, 213 and 

17 214. Also shown in phantom are a battery 220, a printed circuit board 221 (containing a 

18 microcontroller 222 with built in program store), and two motion detectors 230a, 230b. 

10 By calculating the difference in motion of these two detectors 230a, 230b, 

20 microcontroller 222 can determine the relative motion of detectors 230a, 230b as well as 

21 the direction of motion. The two motion detectors 230a, 230b thus permit 

22 microcontroller 222 to determine which way device 206 is turned. In response to such 

23 motion, microcontroller communicates to controller 205 the manner in which remote 
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control device 206 has been manipulated. Controller 205 alters the image of polyhedron 
204 appropriately. The user oF remote controller 206 selects an option corresponding to 
an image facing the user by pressing an appropriate button the remoie control device. 
(Microcontroller 222 reads or senses the various buttons and other input devices on 
remote control device 206, and provides appropriate signals to controller 205 in response 
thereto.) 

As mentioned above, controller 205 v\ ithin television 200 causes motion of 
polyhedron 204 to mirror motion of controilei' 200. Each face of polyhedron 204 depicts 
one or more menu options that a user can select by pressing appropriate buttons on 
remote a>ntrol device 206. In this way a user can select a television channel, increase or 
lower volume, turn the television on or ofi; select a signal source for the television (e.g. 
selecting between cable TV, a VCR or the intcmet), etc. In addition, one can cause an 
image on one of the polyhedron faces to appear on main portion 201 of the television 
screen. 

In lieu of motion detectors 230a, 230b, other position or motion detection devices 
can be used, e.g. gyroscopes, GPS (global positioning system), or other inertia or position 
tracking devices. 

It is noled that remote control device 206 is different from other types of remote 
control devices. For example, while trackballs cooperate with mechanical structuj es for 
sensing the motion of the trackball, the trackball can only be used with the ball 
mechanically resting against those structures. Remote control device 206 can sense its 
own motion althougli it is not mechanically tethered to other sensors, or does not 
mechanically rest against other sensors. In particular, remote control device 206 does nol 
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1 require a stationary non-moving component lo determine the motion of remote control 

2 device 206. 

3 Remole control device 206 is a preferred structure for manipulating polyhedron 

4 204. However, other structures can be used for manipulating polyhedron 204. e.g. 

5 control buttons or track balls. Fig. 6 illustrates a remote control device 240 comprising a 
(i track ball 242. During use, an operator rotates track ball 242. The rotation of track ball 

7 242 is sensed by remote control device 240, and a signal is communicated by device 240 

K to controller 205 within television 200, which causes polyhedron 204 to rotate. 

9 in another embodiment, a remote control device 244 is used which comprises a 

10 rotating wheel 246 (Fig. 7). During use, an operator rotates wheel 246, which is sensed 

1 1 by remote control device 244. A signal is thus communicated by device 240 to controller 

12 205 witl)in television 200, which causes polyhedron 204 to rotate. 

\^ in the above-mentioned embodiments, video streams are bound lo the various 

u geometric surfaces forming the polyhedron. The polyhedron is rotated by altering the 

J5 world coordinate system thai is applied to the 3D pipeline. In one embodiment, CPU 52 

16 within controller 205 determines what change is to be made to the world coordinate 

17 system to in response to the signal controller 205 receives from remote control device 

18 206 (or l emote control device 240 or 244 as the case may be). 

19 Jn one embodiment, the image on the primary portion 202 of television screen 201 

20 is also bound to a geometric surface by a 3D graphics pipeline. One can rotate or 

21 manipulate the image on primary portion 202 of the television screen using the remote 

22 control device. 
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J Although the geometric surfaces in second portion 203 of the television screen 

2 form a polyhedron in tlie embodiment of Fig. 4. in other embodiments, the geometric 

? surfaces do not Ibrm a polyhedron. 

4 In one embodiment, a band of images 204^ is provided in second portion 203 of 

5 television screen 201 (Fig. 8). One moves band 204' by moving remote control device 

6 206. As band 204' moves (e.g. as symbolized by arrov^ 208), dilTerent images become 

7 visible. For example, image 204a on the far right of band 204' will disappear and image 
K 204b will take its place A new image will appear at the position of image 204c. 

9 One can select an image (or a menu option represented by thai image) by 

10 selecting an image that visually appears parallel to screen 201 of television 200. In olher 

1 1 words, by actuating an appropriate control button on control device 206, the image thai 
\2 appears parallel to screen 20 1 (typically center-most image 204d) is selected, in another 
n embodiment, one can move a cursor (using a control button on control device 206) to 

\i point to a particular image within band 204\ and then actuate another control button to 

15 select thai image (or the menu option represented by that image). Alternatively, one of 

u, the positions along band 204' can be highlighted or otherwise marked as representing an 

17 image to be selected One can move different images to tiie marked position to select that 

IX image. 

19 I3and 204' can be either a "closed band" or an "open band." By "closed band" I 

20 mean a band whereby scrolling band 204' far enough in one direction (e.g. rotating the 

21 band .360 degrees to the right) will eventually result in the same images being returned to 

22 their original position. This is lo be contrasted with an open band of images in which 



wo 00/46680 



PCT/USOO/02870 



24 



1 moving tlic images to the right, for example, will eventually expose a left-most image, 

2 with no image exposed to the left of that left-most image. 

3 Selection of images on a face of polyhedron 204 can be accomplished in a manner 

4 similar to image selection for band 204\ 

3 While the invention has been described with respect to specific embodiments, 

6 those skilled in the art will appreciate that changes can be made in form and detail 

7 without departing from the spirit and scope of the invention. For example, instead of 

8 using a polyhedroji, other multi-face images can be used in the above-described manner. 
Further, a plurality of polyhedra or bands can be depicted and manipulated on a television 

10 screen. Bach face of the polyhedra or bands can include two or more portions tliat can 

1 1 depict various options. As mentioned above, instead of using motion detectors within the 

12 remote control device, position detectors can be used. Different types of display devices 
□ can be used in conjunction with our invention, e.g. CR'f screens, LCD screens, or other 
14 display devices. Accordingly, all such changes come within the invention. 
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1 I claim: 

2 1. Method comprising: 

3 providing a display screen and a control device, said display screen displaying a 

4 plurality of surfaces, an image being depicted on each of said surfaces within said 

5 plurality of surfaces; 

6 actuating a control input to said control device; and 

7 manipulating the orientation of said surfaces in response to said control mput 
8 

9 2. Method of claim 1 wherein said images on said surfaces are provided by a 

10 graphics pipeline. 
11 

12 3, Method of claim 1 wherein at least some of said images comprise video streams. 
13 

14 4. Method of claim 1 wherein said images on said surfaces depict menu options, said 

15 method further comprising the step of selecting one of said depicted options. 
16 

17 5, Method of claim 1 wherein said control device is a remote control device diat 

18 senses the motion and/or position of said remote control device. 
19 

20 6. Method of claim 1 wherein said control device is a remote control device 

21 comprising a rotation wheel, such that a user can rotate said rotation wheel, said step of 

22 manipulating comprising the step of manipulating the orientation of said surfaces in 

23 response to said rotation. 



wo 00/46680 



26 



PCTAJSOO/02870 
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2 7. Method of claim 1 wherein said control device is a remote control device that 

3 comprises a track ball, such that a user can rotate said track ball, said step of 

4 manipulating comprising the step of manipulating the orientation of said surfaces in 

5 response to said rotation of said track ball. 
6 

7 8. Method of claim 1 wherein said surfaces form a polyhedron, said act of actuating 

8 changing the orientation of said polyhedron. 
9 

10 9. Method of claim 8 further comprising the step of applying said images to said 

1 1 polyhedron with a graphics pipeline. 
12 

13 10. Method of claim 1 wherein said surfaces fom a band of images. 
14 

15 11. Method comprising the steps of: 

16 displaying a set of images on a display screen, said images corresponding to a 

17 control option that can be exercised, such that the display of said images represents a 

18 display of a list of control options that can be exercised; 

19 actuating a control to thereby move said plurality of images on said screen, 

20 thereby changing the list of options being displayed that can be exercised. 
21 

22 1 2. Method of claim 1 1 wherein at least some of said images are video images. 
23 
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1 13. Method of claim 1 1 further comprising the step of selecting one of said images, 

2 thereby selecting an option corresponding to said selected image. 
3 

4 14. Method of claim 1 1 wherein said images are arranged as a band of images. 
5 

6 15. Method of claim 1 1 wherein said images are arranged to form a polyhedron. 

7 

8 16. Method comprising the steps of: 

9 displaying a plurality of surfaces on a display screen, an image appearing on said 
to surfaces; and 

1 1 rotating said images in response to actuation of a control device. 

12 

13 17. Method of claim 1 6 wherein the surfaces form a polyhedron. 
14 

15 18. Method of claim 17 wherein said screen comprises a main portion and a 

16 secondary portion, said polyhedron being displayed on said secondary portion, said 

17 method fiirther comprising the step of selecting one of the images of said polyhedron and 

18 displaying said selected image on said main portion. 
19 

20 19. Method of claim 1 6 wherein the surfaces form a band of images. 
21 

22 20. Apparatus comprising: 

23 a display device displaying a plurality of images on a plurality of surfaces; and 
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1 a control device, wherein actuation of said control device rotates said surfaces. 

2 

3 21. Apparatus of claim 20 further comprising a graphics pipeline for generating said 

4 plurality of images on said plurality of surfaces. 
5 

6 22. Apparatus of claim 20 wherein said surfaces form a polyhedron. 

7 

8 23. Apparatus of claim 20 wherein at least some of said images comprise video 

9 images. 
10 

1 1 24. Apparatus of claim 20 wherein each of said images depicts a menu option, and 

12 said control device is a remote control device containing a control for selecting one of 

13 said depicted options. 
14 

15 25. Apparatus of claim 20 wherein said control device is a remote control device that 

16 senses the motion and/or position of said remote control device. 
17 

18 26. Apparatus of claim 20 wherein said control device is a remote control device that 

19 comprises a rotation wheel, such that a user can rotate said rotation wheel, wherein said 

20 graphics pipeline manipulates the orientation of said surfaces in response to rotation of 
2! said wheel. 

22 
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1 27. Apparatus of claim 20 wherein said control device is a remote control device that 

2 comprises a track ball, such that a user can rotate said track ball, said step of 

3 manipulating comprising the step of manipulating the orientation of said surfaces in 

4 response to said rotation of said track ball. 
5 

6 28. Apparatus comprising; 

7 a display screen for displaying a plurality of images, each of said images 

8 corresponding to a control option; 

9 a control device for moving said plurality of images, whereby different sets of 

10 images corresponding to different control options can be displayed on said display 

1 1 screen, said control device also comprising a control element for selecting one of said 

12 options. 
13 

14 29. Apparatus of claim 28 wherein at least some of said images are video images. 
15 

16 30. Apparatus of claim 28 wherein said images are arranged as a polyhedron, the 

17 orientation of said polyhedron being controlled by said control device. 
18 

19 31. Apparatus of claim 28 wherein said images are arranged as a band of images. 
20 

21 32. Apparatus of claim 28 wherein said display screen comprises primary and 

22 secondary regions, said plurality of images being displayed in said secondary region, at 



wo 00/46680 PCT/USOO/02870 

30 

1 least some of said images within said plurality of images corresponding to control options 

2 of what is to be displayed in said primary region. 
3 

4 33. Apparatus comprising: 

5 an image display device; and 

6 a remote control device for being held in a user's hand and for controlling the 

7 image displayed on said image display device, said remote control device detecting the 

8 angle or position at which the user is holding said remote control device. 
9 

10 34. Apparatus of claim 33 wherein said remote control device further comprises two 

1 1 motion sensors and a circuit for calculating the difference between the motion of the two 

12 motion sensors. 
13 

14 35. Apparatus of claim 33 wherem said remote control device further comprises a 

15 gyroscope for sensing motion and/or position of said remote control device. 
16 

17 36. Apparatus of claim 33 wherein said remote control device wherein the position 

18 and/or motion of said remote control device is sensed using a global position system. 
19 

20 37. Apparatus of claim 33 wherein said remote control device determines said angle 

2 1 or position v^thout reference to the position of a fixed non-moving structure 

22 mechanically coupled to a moving structure. 
23 
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1 38. Apparatus of claim 33 wherein said display device comprises a screen for 

2 displaying an image, said image comprising a plurality of faces, the orientation of said 

3 faces being changed in response to the position of said remote control device. 
4 

5 39. Apparatus of claim 38 wherein said plurality of faces form at least one 

6 polyhedron. 

7 

8 40. Apparatus of claim 3 8 wherein said plurality of faces forms a band of images. 
9 

10 41. Apparatus of claim 3 8 further comprising a graphics pipeline for providing an 

1 1 image on each of the faces within said plurality. 

12 

13 42. A remote control device for being held in a user's hand, said remote control 

14 device comprising: 

15 first and second motion sensors; and 

16 a circuit for determining the motion and/or position of said remote control device 

17 based on the motions sensed by said first and second motion sensors, said circuit 

18 providing a signal indicative of the motion and/or position in which the remote control 

19 device is being held. 
20 

21 43. A remote control device for being held in a user's hand, said remote control 

22 device comprising: 

23 a gyroscope; and 
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1 a circuit for determining the motion and/or position of said remote control device 

2 based on motion sensed by said gyroscope, said circuit providing a signal indicative of 

3 the motion and/or position in which the remote control device is being held. 
4 

5 44. A remote control device for being held in a user's hand, said remote control 

6 device comprising: 

7 first and second position sensors; and 

8 a circuit for determining the motion and/or position of said remote control device 

9 based on the positions sensed by said first and second position sensors, said ckcuit 

10 providing a signal indicative of the motion and/or position in which the remote control 

1 1 device is being held. 
12 

13 45. A remote control device comprising a member for being held by the hand of a 

M user, said remote control device providing a signal indicative of the motion and/or 

15 position in which said member is being held without said member being mechanically 

16 coupled to a second structure and generating a signal indicative of the relative motion 

17 between said member and said second structure. 
18 

19 46. A method for using a remote control device, said remote control device 

20 comprising: 

21 first and second motion sensors; and 

22 a circuit for determining the motion and/or position of said remote control device 

23 based on the motions sensed by said first and second motion sensors, said circuit 
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1 providing a signal indicative of the motion and/or position in which the remote control 

2 device is being held, said method comprising: 

3 moving said remote control device; and 

4 causing said circuit to calculate the motion and/or position of said remote control 

5 device; and 

6 providing a signal indicative of said motion and/or position. 

7 

8 47. A method for using a remote control device, said remote control device 

9 comprising: 

10 a gyroscope; and 

1 1 a circuit for determining the motion and/or position of said remote control device 

12 based on motion sensed by said gyroscope, said circuit providing a signal indicative of 

13 the motion and/or position in which the remote control device is being held, 

14 said method comprising the step of moving said remote control device; and 

15 causing said circuit to emit a signal indicative of the motion and/or position of 

16 said remote control device. 
17 

18 48. A method for using a remote control device, said remote control device 

19 comprising first and second position sensors, said method comprising the steps of: 

20 calculating the position and/or motion of said remote control device in response to 

2 1 the position sensed by said position sensors; and 

22 providing a signal indicative of said calculated position and/or motion. 
23 
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2 49. A remote control device comprising a member for being held by the hand of a 

3 user, said remote control device providing a signal indicative of the motion and/or 

4 position in which said member is being held without said member being mechanically 

5 coupled to a second structure and genemting a signal indicative of the relative motion 

6 between said member and said second structure. 
7 

8 50. A method for using a remote control device, said remote control device 

9 comprising: 

10 a member for being held by the hand of a user, said remote control device 

1 1 providing a signal indicative of the motion and/or position in which said member is being 

12 held without said member being mechanically coupled to a second structure and 

13 generating a signal indicative of the relative motion between said member and said 

14 second structure, 

15 said method comprising: 

16 grasping said remote control device and moving said remote control device to 

17 thereby cause said remote control device to generate a signal indicating the motion and/or 

18 position of said remote control device. 
19 
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